From b34625363a1a2e20483510d615408418ea626be1 Mon Sep 17 00:00:00 2001 From: Christopher Davis Date: Wed, 29 Sep 2021 15:20:37 -0700 Subject: [PATCH] gtkflowbox: Add remove_all() Removing all items from containers is a common use case. Without this applications needed to implement this manually. It makes senses to handle it here. --- gtk/gtkflowbox.c | 26 ++++++++++++++++++++++++++ gtk/gtkflowbox.h | 3 +++ 2 files changed, 29 insertions(+) diff --git a/gtk/gtkflowbox.c b/gtk/gtkflowbox.c index 8650c5a51e..1b8dacc69c 100644 --- a/gtk/gtkflowbox.c +++ b/gtk/gtkflowbox.c @@ -3098,6 +3098,32 @@ gtk_flow_box_remove (GtkFlowBox *box, g_signal_emit (box, signals[SELECTED_CHILDREN_CHANGED], 0); } +/** + * gtk_flow_box_remove_all: + * @box: a `GtkFlowBox` + * + * Removes all children from @box. + * + * This function does nothing if @box is backed by a model. + * + * Since: 4.12 + */ +void +gtk_flow_box_remove_all (GtkFlowBox *box) +{ + GtkFlowBoxPrivate *priv = BOX_PRIV (box); + GtkWidget *widget = GTK_WIDGET (box); + GtkWidget *child; + + g_return_if_fail (GTK_IS_FLOW_BOX (box)); + + if (priv->bound_model) + return; + + while ((child = gtk_widget_get_first_child (widget)) != NULL) + gtk_flow_box_remove (box, child); +} + /* Keynav {{{2 */ static gboolean diff --git a/gtk/gtkflowbox.h b/gtk/gtkflowbox.h index 80c9f2939d..26bc71ab80 100644 --- a/gtk/gtkflowbox.h +++ b/gtk/gtkflowbox.h @@ -159,6 +159,9 @@ void gtk_flow_box_insert (GtkFlowBox GDK_AVAILABLE_IN_ALL void gtk_flow_box_remove (GtkFlowBox *box, GtkWidget *widget); +GDK_AVAILABLE_IN_4_12 +void gtk_flow_box_remove_all (GtkFlowBox *box); + GDK_AVAILABLE_IN_ALL GtkFlowBoxChild *gtk_flow_box_get_child_at_index (GtkFlowBox *box, int idx); -- 2.30.2